<?xml version = '1.0' encoding = 'UTF-8'?>
<HBRRepo><variables><variable name="PeriodsVar" type="members" usage="const" id="1" product="Planning"><property name="application">SalesPln</property><property name="plantype">OEP_GSP</property><property name="dimension">Period</property><property name="dimensionInputMode">name</property><property name="display_label">Period</property><property name="prompt_text">ID_PRMTEXT_GSP_PERIODS</property><property name="scope">87654321</property><property name="seeded">true</property><value>&amp;OEP_CurMnth</value></variable><variable name="VersionVar" type="member" usage="const" id="3" product="Planning"><property name="application">SalesPln</property><property name="plantype">OEP_GSP</property><property name="dimension">Version</property><property name="display_label">VersionVar</property><property name="prompt_text">ID_PRMTEXT_GSP_VERSION</property><property name="scope">87654321</property><property name="seeded">true</property><value>OEP_Working</value></variable><variable name="YearsVar" type="members" usage="const" id="2" product="Planning"><property name="application">SalesPln</property><property name="plantype">OEP_GSP</property><property name="dimension">Years</property><property name="display_label">Years</property><property name="prompt_text">ID_PRMTEXT_GSP_YEARS</property><property name="scope">87654321</property><property name="seeded">true</property><value>"No Year"</value></variable></variables><rulesets/><rules><rule id="1" name="OGS_RptTotals to GSP" product="Planning"><property name="application">SalesPln</property><property name="plantype">OEP_GSP</property><property name="seeded">true</property><variable_references><variable_reference name="PeriodsVar" id="1"><property name="application">SalesPln</property><property name="hasvalue">true</property><property name="hidden">false</property><property name="plantype">OEP_GSP</property><property name="rule_name">OGS_RptTotals to GSP</property><property name="seq">1</property><property name="type">4</property><property name="useAsOverrideValue">false</property><property name="value">&amp;OEP_CurMnth</property></variable_reference><variable_reference name="VersionVar" id="3"><property name="application">SalesPln</property><property name="hasvalue">true</property><property name="hidden">false</property><property name="plantype">OEP_GSP</property><property name="rule_name">OGS_RptTotals to GSP</property><property name="seq">2</property><property name="type">3</property><property name="useAsOverrideValue">false</property><property name="value">"OEP_Working Bottom Up"</property></variable_reference><variable_reference name="YearsVar" id="2"><property name="application">SalesPln</property><property name="hasvalue">true</property><property name="hidden">false</property><property name="plantype">OEP_GSP</property><property name="rule_name">OGS_RptTotals to GSP</property><property name="seq">3</property><property name="type">4</property><property name="useAsOverrideValue">false</property><property name="value">&amp;OEP_CurYr</property></variable_reference></variable_references><script type="groovy">/* RTPS:  {PeriodsVar} {YearsVar} {VersionVar}*/
def calcScript = new StringBuilder()

List&lt;String> CustomDimensions=[];
List&lt;String> CustomRelDimensions=[];
List&lt;String> CustomAnyDimensions=[];
List&lt;String>  periods=rtps.PeriodsVar.members.name;
List&lt;String>  years=rtps.YearsVar.members.name;
String version = rtps.VersionVar.member.name;
String EntityDim="";
int iCnt;
boolean isCurrencyApp= false

Application app=operation.getApplication();

Cube gsp=app.getCube("OEP_GSP");
List&lt;Dimension> dimlist=app.getDimensions(gsp);

for (Dimension dim : dimlist) {
	DimensionType dType=dim.getType();
	if ((dType==DimensionType.CUSTOM &amp;&amp; dim.name != "Plan Element")) {
		CustomRelDimensions.add('''"OEP_Total '''+dim.getName()+'''"''');
		CustomAnyDimensions.add('''"OEP_Any '''+dim.getName()+'''"''');
		CustomDimensions.add(dim.getName());
	}
	if (dType==DimensionType.CURRENCY) {
		isCurrencyApp=true;
	}
	if (dType==DimensionType.ENTITY) {
		EntityDim=dim.getName();
	}
}

/*Calc Script */

/*Main fix*/
calcScript&lt;&lt;"""

    FIX ( ${fixValues(rtps.VersionVar)}, OEP_Actual,"OGS_Sales Revenue"
    """

calcScript.append(''',@Relative("OEP_Total '''+EntityDim+'''",0)''');
if (years.size()>0) {
	//calcScript.append(''','''+years.join(''',''')+'''\n''');
	calcScript.append(''','''+"${years.collect{ '"' &lt;&lt; it.toString() &lt;&lt; '"'}.join(',')}")
}

if (periods.size()>0) {
	calcScript.append(''','''+periods.join(''',''')+'''\n''');
}

if (isCurrencyApp==true) {
	calcScript.append(''',@levmbrs(Currency,0)''');
}
calcScript.append(''')\n''');
calcScript.append('''	FIX(''')
calcScript.append(CustomAnyDimensions.join(''','''));
calcScript.append(''')\n''');

/*Copies data from Reporting Cube to Any Members*/
calcScript&lt;&lt;'''  "OGS_Base Forecast"(
"OGS_Base Forecast"=@XREF(_GSPREPCube_,Periodic'''
if(version!="OEP_Working Bottom Up") {
	calcScript.append(''',"OEP_Working Bottom Up"''')
}

calcScript.append(''','''+CustomRelDimensions.join(''',''')+'''\n''');
calcScript.append(''');\n''');

calcScript&lt;&lt;'''
);
endfix
ENDFIX'''
println(calcScript.toString())
return calcScript.toString()
</script></rule></rules><components/><deployobjects><deployobject product="2" application="salespln" plantype="oep_gsp" obj_id="1" obj_type="1" name="OGS_RPTTOTALS TO GSP"/></deployobjects></HBRRepo>